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(57) Abstract: A system and method to allow a userof instant messaging chat modules in a network to share identity-based activity 
^ active content of the certain user, and related information with contacts. For example, the user's instant messenger contacts may 
it or current active content, ongoing and recent online activity, etc., of another user. A sender peer includes an application 
_ activate a media content tile from a content repository, or perform online activities through an activity server. The sender 
peer also includes a chat module, which detects identity-based activity and active content, and sends related indications to a recipient 
peer. The recipient peer includes a chat module to display identity-based activity and active content based on the indications and an 
application module to activate related content files. A content enhancement server provides supplemental content information for 
display at the recipient peer and content previews. The content enhancement server also enables a transaction related to the content 
file such as a purchase of an MP3 copy of the content. 
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Background of the invention 

5 Vn .fx> of the Invention 

[0001] This invention pertains generally to chat networks, and more particularly, to 
sharing active content, identity-based activity, and related information with another peer. 

nmntnmow of Related Art 

[0002] Instant messaging has recently emerged as a powerful communications model for 
10 both business and personal communications. Instant messaging software applications such as 
Apple Computer's iChat™, America (Mine's Instant Messenger™, Microsoft Corp.'s MSN 
Messenger™, and others allow users to communicate instantly with other users over a peer 
network. These applications permit users to track other users that are currently logged in and 
to send them real time text messages. Users typically maintain a contact or buddy list of 
/ 5 preferred contacts that are friends, family, co-workers, or others having common interests, etc. 

[0003] However, these instant messaging applications are limited to sharing simple and 
direct text communications between contacts whereas computer uses are expanding beyond 
the conventional text-based functions. Convergence between computers and digital 
entertainment devices has led to computers that serve as an entertainment center to play music, 
20 watch movies, and enjoy other multimedia content Additionally, computer users are spending 
more time with online activities such as playing games and conducting transactions. This 
content and activity, although potentially of interest to a contact, is not easily shared with 
those contacts. 

[0004] Existing instant messaging applications limit real time content and information 
25 shared between a user and a contact to, foT example, text messages, simple graphic files, and 
static file transfers. Significantly, current instant messaging applications do not allow users of 
a peer to directly and easily share content active on a user's computer or other activities of a 
user on the Internet. Active desktop content and web-based activities of a contact are not 
communicated in conjunction with current applications. Active content, as used herein, 
30 includes files that a user is currently accessing, such as music files the user is currently 

listening to, movies the user is currently watching, or the like. Identity-based activity, as used 
herein, includes broader activities of a particular user such as web-based auctions and 
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transactions. Thus, if a user is listening to a music file on his computer, those contacts he rr 
be currently instantly messaging cannot hear the same file at the same time. 



[0005] At best, in order to share such files, the sender must transfer the file via a file 
transfer function of the instant messaging application or as an attachment to an email sent by 
5 an email application, or a user can send a URL to a file if its available on the Internet. This 
process is not real time sharing of active content, but is essentially copying the static file (or a 
reference to it) from one computer to another. Further, neither approach provides the recipient 
with real time updates such as a change in active content, a list of recently activated content, 
nor synchronization. 

[0006] Furthermore, there is no network architecture to automatically enhance the 
recipient's use active content and/or active content information. Typically, a recipient of a 
static content file has to undertake additional manual steps to obtain such additional 
information. Again, if a user is listening to a music file, the user's instant messaging contacts, 
even those currently in a chat session, would not have direct access to information or meta- 
data such as the song's name, artist, album art, liner notes, or the like. More generally, there is 
no way for a user of an instant messaging application to retrieve supplemental information 
about the active content in use on another user's computer from a database. Similarly, such 
instant messaging contacts of the user cannot today easily or directly purchase or preview a 
copy of the content within the instant messenger. 

20 [00071 Furthermore, there is no way to track a user's activities within the instant 

messaging applications. For example, contacts tell what music files he has recently listened 
to, such as the last file music files. Nor can users share information regarding web activities 
such as recent content purchases, current online auctions, previews or downloads. 

[0008] Another problem with existing messenger applications is that they are typically 
stand-alone applications that provide only messaging functionality. However, users often 
multitask between several applications on a single desktop, and typically have an instant 
messaging application running concurrently with other applications, such as word processors, 
spreadsheets, graphic applications, media applications, and the like. Thus, user must toggle 
between the instant messaging application to communicate with their contacts and other active 
applications to perform tasks such as playing back multimedia or surfing web sites, and 
performing word processing. 
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[0009] Accordingly, there is a need for more robust instant messaging applications that 
enable active content and identity-based activity sharing. The solution should provide 
supplemental information about content and activities, and also related recipient transactions. 

SUMMARY OF THE INVENTION 

5 [0010] The present invention meets these needs by allowing instant messaging 

applications to track and share identity-based activity and active content of a user with the 
user's contacts. Advantageously, the present invention provides an enhanced communication 
experience between a user and remote contacts that includes entertainment and online 
activities. 

10 [0011] In one embodiment, a system comprises a content daemon on a sender peer to 
track active content of a user and identity-based activity. Active content includes files that a 
user is currently accessing, such as music files the user is currently listening to, movies the 
user is currently watching, and the like. Identity-based activity includes broader activities of a 
specific user, such as web-based auctions posted by or transactions conducted by a user 

15 logged-in to a chat module, and active content previously viewed by the user. The chat 

module shares identity-based activity with a remotely located recipient peer through a network 
by sending information collected by the content daemon. The recipient chat module displays 
identity-based activity and/or related information to the contact. 

[0012] In another embodiment, the content daemon tracks user activity by, e.g., polling 
20 application modules for current active content and identity-based activity, and storing the 
information in a list kept by a content information database. The application module 
comprises a media player, a web browser, or other application for activating content and/ or 
performing user activities. The list includes, for example, the last five audio files listened to 
by the user, recent downloads, an online auction or transaction conducted by the user, etc. In 
25 one embodiment, the list is populated with unique identifiers. For active content, an 
exemplary unique identifier is an ID3 tag for MP3s; and for identity-based activity, an 
exemplary unique identifier identifies a specific user's auction with e.g., a URL or a key. In 
another embodiment, the content daemon detects identity-based activity in an application 
module that is in communication wife an. activity server. The activity server hosts online user 
30 activities such as online auctions or transactions. In response, the content daemon records the 
unique identifier associated with the identity-based activity. 
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[0013] In yet embodiment, a content enhancement server includes a content supplement 
database to provide supplements to identity-based activity information to the recipient peer. 
Supplemental information can include descriptive information about the content metadata, or 
additional information, such as name, creator, content descriptions, related files and so forth 

5 (e.g., a CD containing the active media, a graphic file of the artist, a preview, or transactional 
information to obtain a copy). In another embodiment, the content supplement database stores 
previews of content for streaming to the recipient peer. The content enhancement server also 
includes a content transaction module to enable a transaction based on the shared content 
information. The content enhancement server, for example, enables a purchase a copy of a 

0 shared music file. In another embodiment, the content transaction module serves as a gateway 
to third-party databases with available products by using application program interfaces to 
search the third-party databases and generate a list of available products. 



Brief Description of the Drawings 
15 [0014] FIG. 1 is a block diagram illustrating a system for sharing identity-based and/or 
active content information according to an embodiment of the present invention. 

[0015] FIG. 2 is a block diagram iUustratmg a peer according to one embodiment of the 
present invention. 

[0016] FIG. 3 is a block diagram iUustratmg a chat module according to an embodiment 
20 of the present invention. 

[00171 FIG. 4A is an illustration of a user interface displaying a recipient peer's chat 
module with integrated active content information according to one embodiment of the present 



[00181 FIG. 4B is an illustration of a user interface displaying a recipient peer's chat 
25 module with integrated identity-based activity according to one embodiment of the present 



[0019] FIG. 4C is an illustration of a user interface displaying a recipient peer's 
application module with an integrated chat module. 

[0020] FIG. 5 is a block diagram illustrating the content enhancement server according 
30 to an embodiment of the present invention. 
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[0021] FIG. 6 is a sequence diagram illustrating a method of sharing identity-based 
content information according to an embodiment of the present invention. 



[0022] FIG. 7 is a sequence diagram illustrating a method of completing a transaction in 
the content enhancement server concerning content according to an embodiment of the present 
5 invention. 

[0023] FIG. 8 is a sequence diagram illustrating a method of streaming active content to 
the recipient peer according to an embcxliment of the present invention. 

[0024] FIG. 9 is a sequence diagram illustrating a method of sharing active content 
according to an embodiment of the present invention. 

; 0 [0025] FIG. 10 is a sequence diagram illustrating a method of completing a transaction 
in the content enhancement server concerning shared active content according to an 
embodiment of the present invention. 

[0026] FIG. 1 1 is a sequence diagram illustrating a method of streaming active content 
between the sender peer and the recipient peer according to an embodiment of the present 
IS invention. 



Detailed Description of the Preferred embodiments 
[0027] In the following description, for purposes of explanation, numerous specific 
details are set forth in order to provide a thorough understanding of the invention. The field of 

20 networking is such that many different variations of the illustrated and described features of 
the invention are possible. Those skilled in the art will undoubtedly appreciate that the 
invention can be practiced without some specific details described below, and indeed will see 
that many other variations and embodiments of the invention can be practiced while still 
satisfying the teachings of the invention. Further, those of skill in the art of networking 

25 appreciate the large variety of different nelvvorking protocols, topologies, transports, and the 
like that can be used to establish networked communications between computers. 
Accordingly, the present invention should not be understood as being limited to the specific 
implementations described below. 

[0028] FIG. 1 is a block diagram illustrating a system 1 00 for sharing identity-based 
30 and/or content information according to an embodiment of the present invention. The system 
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100 includes a sender peer 110, a recipient peer 120, a content enhancement server 130, and an 
activity server 140, each communicatively coupled to a network 145. Those of skill appreciate 
that the designation of a peer as sending or receiving is not fixed, and that in practice a peer is 
sometimes sending data and sometimes receiving data; ftat is, the designation of a peer as 
5 sending or receiving is merely for purposes of explanation and does not limit a peer to only 
that function. 

10029] As discussed, active content refers to a data file in current use at a peer, such as 
real-time content. The data file in use may be media content such as an audio or video file 
being played back in a media player, text, graphics, or numeric content such as a document, 

0 spreadsheet, code file, graphics file, or any oilier file having data representing content that is 
capable of perception by a user at the peer. Active content also refers to related active content 
information such as meta-data about the data file (e.g., size, title, author, location, date, 
content list), an auxiliary data file related to the data file (e.g., unique identifier, associated 
graphics, text, references to other files), transaction information, a unique identifier, or any 

J ofter information directly or indirectly related to the content. 

[0030] Additionally, identity-based activity refers to broader activities specific to a user, 
such as web-based auctions or transactions conducted by the user, active content previously 
viewed by the user, and other events related to content accessible by other peers. Although 
content may be active, it need not be executing in real-time or locally (e.g„ current web-based 
) auctions or recent web purchases of a user), The content can be viewed with an application 
such as a web browser or other interface. Identity-based activity also refers to related 
information such as the duration of an auction, a URL, a unique identifier, a last update time, 
etc. 

[0031] The sender peer 1 1 0 provides identity-based activity of contacts to a user and 
f sends identity-based activity of the user to a contact's peer on the network 145. In general, a 
peer is some type of computing device (physical or virtual), such as a computer, a telephone, 
set top box, a network appliance, gaming console, entertainment device, or any device capable 
of connecting to the network 145 and receiving identity-based activity. In one embodiment, 
the sender peer 110 displays active content such as a multimedia file, and then sends related 
' information to the recipient peer 120 for display. In another embodiment, the sender peer 1 1 0 
sends unique identifiers of online auctions to contacts. Further embodiments of the sender 
peer 1 10 and methods operating therein are discussed below. 
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[0032] The recipient peer 120 receives and outputs active content and identity-based 
activity of contacts. The recipient peer 120 also communicates with the content enhancement 
server 130 to retrieve enhancements and enable transactions. The recipient peer 120 can be 
any embodiment of the first peer, so output may be displayed in a GUI. In one embodiment, 
5 the sender peer 110 receives and displays a contact's recent online book purchases. In another 
embodiment, the sender peer 110 displays online sales conducted by contacts, and 
subsequently receives updates from the activity server 140. 

[0033] In another embodiment, the recipient peer 1 20 is a thin version of the sender peer 
1 10 in that it has the capability to receive active content, but not necessarily the capability to 
f o activate the stream of the active content For example, a telephone having the chat module 
(e.g., an SMS compatible text messaging module) receives active content information, but 
may not have the multimedia player needed for local playback. Further embodiments of the 
recipient peer 1 20 and methods operating therein are discussed below. 

[0034] The content enhancement server 130 provides supplemental information about 
1 5 active content and identity-based content to the recipient peer 120, and enables related 

transactions. The enhanced content server 130 is, for example, a server application residing on 
a network destination. The content enhancement server 130 may be part of a central peer 
server, or part of an independent third-party server compatible with the protocol used by peers 
in the system 100 such as iTunes Music Store. Further embodiments of the content 
20 enhancement server 130 and methods operating therein are discussed below. 

[0035] In one example of the system 100, two users, one at the sender peer 1 1 0 and one 
at the recipient peer 120 exchange text messages through iChat, while the sender user also 
listens to MP3s with iTunes. The receiver user notices identity-based activity concerning 
recent MP3s played back by the sender user and turns the conversation towards those songs. 
25 The receiver user consequentially decides to preview the music, initiating a stream from the 
content enhancement server 130 (or the sender peer 1 10) to the recipient peer 120. Ultimately, 
the sender user purchases a copy from the iTunes Music Store. 

[0036] The activity server 140 hosts web-based user activities. The activity server 140 
may be a computer running an application such as an HTML or FTP server. The user activity 
30 includes web-based services such as online auctions, games, entertainment, sales, downloads, 
transactions, or the like. Preferably, the activity is publicly available such that any contact can 
access and participate in the same or similar activity. For example, a user of a recipient peer 
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120 who wants to order a movie recently downloaded or purchased by a contact is directed to 
the activity server 140 to perform the same download or purchase. In another example, a 
contact is directed to a current advertisement 

[0037] The network 145 transports data packets containing content information between, 
5 e.g., the sender peer 1 10, the recipient peer 120, and the content enhancement server 130. The 
network 145 may be a data network, a telephone network, or any other type of network 
capable of transporting data. The data may be video, audio, information, or otherwise. The 
network 145 can be public or private, including both wired and wireless portions, send data in 
packets or through circuits, and use communications protocols such as IP (Internet Protocol) 
10 or ATM (Asynchronous Transfer Mechanism). Combinations of the previous and variations 
of network communication are within the scope of the present invention since it is transport 
independent. 

|00381 Examples of alternative embodiments of the system 100 include, an embodiment 
having more than two peers, an embodiment having peers without the content enhancement 
15 server 1 3 0, and an embodiment having peers communicatively coupled through a first network 
145 and one of the peers communicatively coupled to the content enhancement server 130 
through a second network 145. In particular, FIG. 1 shows only two peers for illustration, but 
in actual practice, there will large number of peers. 

[0039] FIG. 2 is a block diagram fflustratmg a peer 200 according to one embodiment of 
20 the present invention. The peer 200 includes a chat module 210, an application module 230, 
and a content repository 240. The hardware portions of a peer (e.g., storage devices, memory, 
microprocessor, buses, etc.) are not illustrated, and can be of any conventional or equivalent 
design. 

[0040] The chat module 2 1 0 sends and receives active content and identity-based 
25 activity to and from other chat modules. The chat module 2 1 0 connects to a centralized 
messenger service located on the network 145 to set-up and/or conduct communication with 
other peers. The centralized messenger service may be Apple Computer Inc.'s iChat™, 
America Online's AIM™, an instant messaging module or the like. Peers can communicate 
with each other, with their messages passing through the messenger service, or directly with 
30 each other independently of the centralized messenger server. The chat module 2 1 0 may 
periodically communicate with the centralized messenger service to update communication 
with other peers such as setting-up connections with new peers and changing communication 
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addresses of existing peers. Although the present embodiment utilizes a cbatmodule 210 to 
share active content and identity-based activity other embodiments may integrate such sharing 
into different peer-to-peer communications modules such as an FTP module 01 other file 
sharing application. 

5 [0041] The content daemon tracks 220 active content and user activity by polling the 
application module 230. If there is active content of activity, the content daemon 220 collects 
related information, e g,, meta-data about a file in use or a URL of a user's online posting. In 
another embodiment, the content daemon 220 receives information sent automatically by the 
application module 230. In another embodiment, the content daemon 220 is configured to 

/ 0 exclude certain active content and identity-based activity, such as confidential information, 
from si 



(0042] In one embodiment, the content daemon 220 is integrated into an operating 
system running on the peers. The operating system is for example, Mac OS X by Apple 
Computer, Inc. of Cupertino, CA or Windows XP by Microsoft Corp. of Redmond, WA. 
Integration includes software code of the operating system itself, a plug-in module that 
interoperates with the operating system, or any other background process that receives 
messages from the operating system related to active content and identity-based activity. The 
operating system notifies the content daemon module 220 of active application modules 230 
and content and/or activities therein. 

[0043] The content daemon 220 further comprises a content information database 225 
that generates and stores information about recently activated content and identity-based 
activity shared with other peers. The content information database 225 comprises, for 
example, a table for each user of a peer that contains categories, and lists instances within each 
category. Content information may be meta-data about the content file such as its size, an 
auxiliary data file related to the data file such a unique identifier, related image file, content 
title, content source, or any other information directly or indirectly related to the content The 
content information database 330 receives queries containing an identifier such as an MP3 ID 
tag received from, e.g., the chat module 210 or the application module 230. In response, the 
content information database 220 makes matching information available to the chat module 
210, such as the MP3 content title. The mformation can be displayed at the sender peer 110, 
sent to the recipient peer 120 for display, or sent to the content enhancement server 130. 
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10044] The content information database 225 may also store activity information such as 
recent or ongoing online transactions. In one example, responsive to the content daemon 220 
detecting a book or MP3 purchase, the content information database 225 may update a list of 
the five most recent books on MP3 purchases. In another example, the content daemon 220 
5 records a URL containing a user's auction. Additionally, the content information database 225 
uses an API for the auction service to obtain information such as an item's description or 
auction expiration time. 

[0045] The unique identifier comprises an active content fingerprint such as a hash key 
or wavelet. The hash key can be detenmned from an algorithm implementing a mathematical 
» transform on binary data such as SHA-1 or CRC32. The unique identifier may be used by the 
recipient peer 120 to retrieve locally stored active content information related to the file, or 
sent to the content enhancement server 130 to retrieve active content supplements as described 
below. 

[0046] The application module 230 includes active content 235. The application module 

> 230 may be application software, hardware, or a combination such as a media player, a web 
browser, a word processor, or the like. To activate the data file, the application module 230 
opens at least a portion of the data file and progresses through the data file either sequentially 
or otherwise. For example, a media player loads a portion of an audio file into a buffer 
representing the next ten seconds of audio playback. Besides locally executed files, the 

> application module 230 serves as a conduit to online activities. For example, a web browser 
loads a web page containing user activity. 

[0047| The content repository 240 stores data files that are activated by the application 
module 230. The content repository 240 may be a hard disk, flash memory, random access 
memory, or any device capable of non-volatile or volatile storage of data files. The data files 
contain data in any useful format, such .mpg, .wma, .omg, .gif, .mp3, .doc, .txt, .pdf, or any 
format capable of execution by the application module 230. In one embodiment, the content 
repository 240 is networked to the sender peer 1 10 such as a personal digital assistant with 
data files connected to the peer via the Bluetooth wireless communications protocol. 

[0048] FIG. 3 illustrates a block diagram of the chat module 2 1 0 according to an 
embodiment of the present invention. The chatmodule 210 comprises a communications 
module 3 10, a server/client module 320, a content information database 330, and a GUI 
module 340. 
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[0049] Hie communications module 310 provides a communications pathway for the 
chat module 210 to transmit messages, and to share active content and identity-based activity 
through the network 145. The communications module 310 logs-in to tire centralized chat 
server and establishes point-to-point communication with other peers by exchanging network 
5 addresses such as IP addresses. The communications module 310 may further comprise a 
network interface, appropriate protocol software, an operating system or port control, a peer 
network software, or and application software. 

[0050] The server/client module 320 sends active content and identity-based activity for 
output at the other peers, and receives the same. Additionally, the server/client module 320 
10 streams active content to a recipient peer 120. The server/client module 320 comprises, for 
example, an FTP server, a desktop sharing server, an audio/video server, or any other device 
capable of sending and receiving active content and identity-based activity through a network. 

[0051] The GUI module 340 provides a user interface of the chat module 210 and 
receives user commands related to displayed information. In the recipient peer 120, the GUI 
15 module 340 integrates the information into the chat module' s 2 1 0 user interface as discussed 
below in regards to FIG. 4. The GUI module 340 receives user commands to, for instance, 
initiate a stream or initiate a transaction. The GUI module 340 may include a graphical 
engine, an audio/video CODEC, a processor, an operating system, graphic software, and other 
graphics enhancing devices. 

20 [0052] FIG. 4A is an illustration of a user interface displaying a recipient peer's chat 
module 400 with integrated active content information according to one embodiment of the 
present invention. One of ordinary skill of the art will recognize that FIGs. 4A-C are merely 
illustrative examples and that there are many variations within the scope of the invention. The 
chat module display 400 comprises contacts 411, 421, 431 which are other peers on the 

25 network and, if there is any, each contact's active content information 412, 422. The contacts 
are a list of peers, which may be personal contacts, co-workers, or any other peers on the 
network 145. 

[0053] A music icon indicates that the user of Peer 1 is listening to a song, which in this 
example is "Dorset Perception" by Simon Pasford. In response to selecting the icon, the chat 
30 module 210 may initiate an active content stream, enable a purchase, retrieve content 

supplements, etc. In one embodiment, response to selecting a hyperlink associated with the 
song title or artist, a list of similar songs, or other songs by the artist is returned. 

11 
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[0054] The representation of Peer 2 does not include information about active content at I 
Peer 2. In one embodiment, Peer 2 does not send information about active content because, i- 
for example, there is no currently active content at Peer 2 or because Peer 2 has is not \ 
configured to share active content with the recipient peer 120. In another embodiment, the 
5 chat module 2 1 0 does not display received active content information because, for example, 
the recipient peer 120 is not capable of receiving an active content stream, or not capable of 
activating streamed content. 

[0055] The representation of Peer 3 includes an icon indicating that the active content 
432 at Peer 3 is a movie titled "The Third Man," and that this movie is available for purchase. 
J 0 In response to selecting the icon, the chat module 2 1 0 enables a transaction. 

[0056] FIG. 4B is an illustration of a user interface displaying a recipient peer's chat 
module 400 with integrated identity-based activity according to one embodiment of the 
present invention. The identity-based activity of this example comprises recently downloaded 
songs from iTunes. In one embodiment, activating the song hyperlink initiates a transaction 
/ 5 such as a purchase of the song from iTunes. In another embodiment, activating the artist 

hyperlink returns a list of other MP3 s by the artist. I 

[0057] FIG. 4C is an illustration of a user interface 450 displaying a recipient peer's 
application module with an integrated chat module. The user interface includes an application 
module display 470 and a chat module display 460. The user interface may be rendered by a 
20. GUI to display in an application module 23 0. 

[0058] The application module display 470 further includes an active content display 
47 1 to output the content currently available to a peer. For example, the display can show 
active video content in response to that same content being displayed on the sender peer's 1 10 
active content display. 

| 

25 [0059] The chat module display 460 further includes a representation of Peer 1 and a i 
chat session 462. Peer 1 is preferably a peer having active content compatible with the ] 
application module 230. The chat session 462 is disposed within the user interface to allow \ 
access to messaging while viewing active content. Advantageously, the peer user need not 
toggle between application windows when messaging a peer about shared active content. \ 
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[0060] FIG. 5 is a block diagram illustrating the content enhancement server 1 30 
according to an embodiment of the present invention. Hie content enhancement server 1 30 
includes a content supplement database 520 and a content transaction module 530. 

[0061] The content supplement database 520 queries file descriptions to provide the 
5 recipient peer 1 20 with data files related to content. The data Files may contain information 

similar to that stored in the content information database 225 and the content repository 240, 

or more loosely related to the shared active content such as data files of advertisements. 

Accordingly, a query for a music artist may return a new book about the artist or their latest 

CD. The query may use a unique identifier such as a hash key if available. In one 
10 embodiment, the content supplement database 520 streams content to the recipient peer 120. 

In another embodiment, the stream is a preview. The content supplement database 520 and 

methods operating therein are described in further detail below. 

[0062] The content transaction module 530 facilitates transactions with the recipient peer 
120 such as content purchase. The content transaction module 530 includes a database of 
15 available products. Selected products are identified by a tag or unique identifier received from 
the recipient peer 120. The content transaction module 530 receives an order for the product 
and stores a resulting transaction ticket. 

[0063] In another embodiment, the content transaction module 530 enables transactions 
between the recipient peer 120 and third-party retailers. The content transaction module 530 

20 sends queries to several third-party databases according to the third patty's application 

program interface. Based on the results, the content transaction module 530 generates a list of 
products with hyperlinks to third-party web sites containing the products. The content 
transaction module 530 also stores each third-party web site impression and click-through 
from the hyperlink list. The content transaction module 530 and methods operating therein are 

25 described in further detail below. 

[0064] Advantageously, the recipient peer 120 is able to automatically access 
supplemental information about shared active content and is easily able to obtain a copy of 
content or a related product. 

[0065] FIG. 6 is a sequence diagram illustrating a method of sharing identity-based 
30 activity in the system 100 according to an embodiment of the present invention. The sending 
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and recipient peers 11 0, 120 independently establish 6 1 0, 660 connections to the peer network 
by presenting an authorized log-in and password to a log-in server. 

[0066] Next, the sender and recipient peers 110, 120 establish 615 a peer-to-peer 
connection to enable direct or indirect communication. Each peer sends a list of contacts or 
5 other parameter to the log-in server for identifying preferred peers. The log-in server returns a 
list of logged-in contacts with network addresses for direct communication or other types of 
identification such as the contact name for indirect communication through the log-in server. 
The log-in server also notifies other relevant peers that new peers have joined the network 
145. The sender peer 110 sends 625 a list of identity based content information from the 
io content information database 225. 

[0067] The sender peer 1 10 sends 625 content information to the recipient peer chat 
module 210 either directly or indirectly through the log-in server. The recipient peer 1 20 
displays or otherwise output the content information to the contact. Additionally, the recipient 
peer 120 requests 645 supplemental information related to the content from the content 
15 enhancement server 130. To check the content enhancement server 1 30, the recipient peer 1 20 
sends an identifier such as a tag or title as described herein. 

[0068] The content supplement database 510 searches 680 its files using a query based 
on the identifier for the content. The query may be filtered by additional parameters such as 
only pictures or only advertisements. If a unique identifier of the content is available, such as 
20 a hash key, the query results are more determinative. Otherwise, the content supplement 
database 5 10 ranks the query results and sends 655 the supplemental content information to 
the recipient peer 120 for display. In one embodiment, the content supplement database 5 1 0 
saves peer-specific queries to use as parameters in future queries. 

[0069] In another embodiment, the content supplement database 5 1 0 searches third party 
25 databases by sending a query using the API of the outside database. Eased on matching the 
queries to database descriptions, the content supplement database 510 determines which 
databases to search. The content supplement database 510 ranks the results and generates a 
list of hyperlinks corresponding to third party websites containing the results. The content 
supplement database 510 may additionaUy store hyperlink impressions or click-throughs from 
30 the list. 
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[0070] The recipient peer 120 displays 670 the active content and/or identity-based 
activity in its user interface. In one embodiment, the recipient peer 120 implements local 
preferences by mnning a local ranking of the received results or by filtering certain results. 
The recipient peer 120 user elects to request a stream of the content from the sender peer 1 10 
5 or the content enhancement server 130 as discussed with respect to FIG. 8. The recipient peer 
120 may alternatively request a transaction from the with the content transaction module 530 
as discussed with respect to FIG 7. 

[0071] The sender peer 110 also sends updates. After the initial identity based content is 
sent, the sender peer 110 initiates 620 the application module 230. In one embodiment, the 

10 application module 230 and the chat module 2 10 are integrated into a single application, so 
both modules are initiated at the same time (e.g., FIG. 4). The sending application module 230 
activates 630 content from the content repository 240 by outputting a portion of the data file 
{e.g., playing back part of an audible e-book). The content daemon 220 detects 640 content 
viewing on the application module 230 and updates the content information database 225. The 

15 sender peer 1 10 sends 635 updated content information to the percipient peer 120. In response 
to the sender peer 1 10 changing 650 content in the application module 230, the sender peer 
110 again sends 635 content information to Hie recipient peer 120. 

[0072] In one embodiment, the content daemon 220 periodically polls the application 
module 230 for content information. In another embodiment, the application module 230 
20 publishes its status to the content daemon 220. In yet another embodiment, the content 

daemon 220 automatically polls the activity server 140, which hosts online web sites such as 
eBay.com or Amazon.com by using an API and/or unique identifier. The web sites return a 
current status of a user's ongoing auction or Tecent book purchases. The API may be 
proprietary, on open standard, or queries that appear to the web sites to originate from a user. 

25 [0073] FIG. 7 is a sequence diagram illustrating a method of completing a transaction 
concerning content according to an embodiment of the present invention. The content 
enhancement server 130 queries a database in the content transaction module 530 in response 
to receiving the request for supplemental content information 645 or otherwise. In the 
example of a purchase transaction, the database query returns a opportunity to purchase, for 

30 example, an MP3 or CD containing a song or a DVD containing a movie. The database query 
also returns related transaction options, such as an option to purchase clothing designed by a 
queried music artist. The content transaction module 530 ranks the query results and sends 
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715 a list of transaction opportunities to the recipient peer 120 for display. The results may be 
displayed as hyperlinks or objects in a java applet. 



[0074] The recipient peer 120 requests 725 transaction processing responsive to a user 
selection 710. In one embodiment, the content transaction module 530 requests further 
5 information from the recipient peer 120 user, such as payment and shipping information. 
Once the transaction terms are completed, the content transaction module 530 requests 845 
transaction confirmation to the user. The transaction is completed when the recipient peer 120 
returns 74 5 a transaction confirmation to the content transaction module 520 . 

[0075] FIG. 8 is a sequence diagram illustrating a method of streaming content to the 
J 0 recipient peer 120 according to an embodiment of the present invention. The content 

repository 520 queries 820 stored content in response to receiving the request for supplemental 
information 645 or otherwise. The content repository 520 sends 815 stream options to the 
recipient peer in any format described herein. The recipient peer 120 requests 825 for a stream 
of content to the content repository 520 responsive to a user input 820. 

15 £0076] Next, the content repository 520 and recipient peer 120 negotiate 835 stream 
parameters such as stream speed. Essentially, the sender peer's server/client module 320 and 
content repository's server/client module (not pictured) provide a direct communication link 
by exchanging port numbers. Additionally, factors may include local preferences, network 
traffic load, and bandwidth requirements of the content. The recipient peer 120 determines 

20 which application modules 230 are compatible with the file type and initiates an application 
module 230. In one embodiment, if the file type is compatible with several application 
modules 230, the recipient peer 120 presents the user with a choice of application modules 230 
for activating the file. 

[0077] The recipient peer 120 activates the content in the application module 230. The 
25 application module 230 may display or otherwise output the shared active content when a 
minrmum amount of data has been received, buffer a certain amount of data, or wait until the 
entire file has been transferred. 

[0078] FIG. 9 is a sequence diagram illustrating a method of sharing active content in 
the system according to an embodiment of the present invention. The sending and recipient 
30 peers 110, 120 independently establish 910, 920 connections to the peer network by presenting 
an authorized log-in and password to a log-in server. 
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[0079] Next, the recipient and senderpeers 110, 120 establish 915 a peer-to-peer 
connection to enable direct communication. Each peer sends a list of contacts or other 
parameter to the log-in server 510 for identifying preferred peers. The log-in 510 server 
returns a list of logged-in contacts with network addresses. The log-in server 5 1 0 also notifies 
5 other relevant peers that new peers have joined the network 145. 

[0080] The sender peer 110 initiates 911 the application module 230. In one 
embodiment, the application module 230 and the chat module 210 are integrated into a single 
application, so both modules are initiated at the same time (e.g., FIG. 4C). The sending 
application module 230 activates 612 content from the content repository 240 by outputting a 
0 portion of the data file. The chatmodule 210 may have a daemon that detects the application 
module 230 running on the peer and periodically polls the application module 230 for active 
content information. In another embodiment, the application module 230 publishes its status 



[0081] The sender peeT 1 10 sends 925 active content information to the recipient peer 
120 chat module 210. The recipient peer 120 may display or otherwise output the active 
content information, or request 916 supplemental information related to the active content 
from the content enhancement server 130. To check the content enhancement server 130, the 
recipient peer 120 sends an identifier such as a tag or title. 

[0082] The content supplement database 520 searches 930 its files using a query based 
on the identifier for the shared active content. The query may be filtered by additional terms 
such as only pictures or only advertisements. If a unique identifier of the active content is 
available, such as a hash key, the query results are more determinative. Otherwise, the content 
supplement database 520 ranks the query results and sends 936 the supplemental active 
content information to the recipient peer 120 for display. In one embodiment, the content 
supplement database 520 saves peer-specific queries to use as parameters in future queries. 

[0083] In another embodiment, the content supplement database 510 searches third party 
databases by sending a query using the application programming interface of the outside 
database. Based on matching the queries to database descriptions, the content enhancement 
database determines which databases to search. The content supplement database 510 ranks 
the results and generates a list of hyperlinks corresponding to third party websites containing 
the results. The content supplement database 510 may additionally store hyperlink 
impressions or click-throughs from the list. 
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[0084] The recipient peer 120 displays 921 the active content information in its user 
interface. In one embodiment, the recipient peer 120 may implement local preferences by 
running a local ranking of the received results or by filtering certain results. The peer may 
also elect to request a transaction from me with the content enhancement server 130 as 
5 discussed with respect to FIG. 8. The peer user may elect to request a stream of the shared 
active content from the sender peer 1 10 as discussed with respect to FIG. S. 

[0085] In response to the sender peer 1 1 0 changing 6 1 3 active content in the application 
module 230, the sender peer 1 10 sends 935 updated active content information to the recipient 
peer 120. The recipient peer 120 displays 922 updated active content information, or 
10 supplemental active content information in the chat module 2 1 0 user interface. 

[0086] FIG. 8 is a sequence diagram illustrating a method of completing a transaction 
concerning shared active content according to an embodiment of the present invention. The 
recipient peer 120 sends 101 5 a request for transaction information to the sender peer 110 
responsive to user input 1020. Accordingly, the sender peer 1 10 sends 1025 a transaction 
15 identifier such as the tag used to retrieve information from the supplemental content repository 
240 or other shared active content information. 

[0087] The recipient peer 120 sends 101 6 the identifier to the content enhancement 
server 130 to query a database in the content transaction database. In the example of a 
purchase transaction, the database query returns a opportunity to purchase, for example, an 
20 MP3 or CD containing a song or a DVD contairung a movie. The database query may also 
send 1026 related transaction options such as an option to purchase clothing designed by a 
queried music artist. The content transaction database ranks the query results and sends a list 
of transaction opportunities to the recipient peer 120 for display. The results may be displayed 
as hyperlinks or objects in a java applet. 

25 [0088] The recipient peer 120 sends 1 036 a transaction selection such as a request to 
purchase a content source to the content transaction module 530 of the content enhancement 
server 130. In another embodiment, (he content transaction module 530 requests further 
information from the recipient peer 120 user such as payment and shipping information. 

[0089] Once the transaction terms are completed, the content transaction module 530 
30 sends 1 046 a request for a transaction confirmation to the user. The transaction is completed 

18 



BNSDOCID: eWO__2005017eS0A2J_> 



WO 2005/017660 PCT/US2004/021516 
when the recipient peer 120 sends 1056 a transaction confirmation to the content transaction 
module 520. 

[0090] FIG. 9 is a sequence diagram illustrating a method of streaming active content 
between the sender peer 1 10 and the recipient peer 120 according to an embodiment of the 
5 present invention. The recipient peer 120 sends 1115a request for a stream of shared active 
content to the sender peer 1 10 responsive to a user input 1 120 by the user of the recipient peer. 

[0091] Next, the sender peer 1 10 and recipient peer 120 negotiate 1 1 25 stream 
parameters such as stream speed. Essentially, the sender peer's server/client module 320 and 
recipient peer's server/client module 320 provide a direct communication link by exchanging 
10 port numbers for the application modules 230. Additionally, the peers may assess local 
preferences, network 145 traffic load, and bandwidth requirements of the shared active 
content. 

[0092] The server/client module 320 in the sender peer 1 10 synchronously streams the 
shared active content to the recipient peer 120. The recipient peer 120 determines which 
/ 5 application modules 230 are compatible with the file type and initiates an application module 
230. In one embodiment, if the file type is compatible with several application modules 230, 
the recipient peer 120 presents the user with a choice of application modules 230 for activating 
the file. 

[0093] The recipient peer 120 application module 230 activates the shared active content 
20 in the application module 230. The application module 230 may display or otherwise output 
the shared active content when a minimum amount of data has been received, buffer a certain 
amount of data, or wait until the entire file has been transferred. 

[0094] The recipient peer 1 20 application module 230 sends shared active content 
information such as a change in display of the file, a change of shared active content, or 
25 termination of active content altogether. 
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1 . A peer for sharing identity-based activity with a plurality of peers, comprising: 

a content daemon to detect and store identity-based activity; and 

an instant messaging module, conxmunicatively coupled to the content daemon, to send 
an indication of recent identity-based activity to at least one of the plurality of 
peers, the recent identity-based activity related to a user logged-in to the instant 



2. The peer of claim 1 wherein identity-based activity comprises content 
1 0 customized by the user that is accessible to the plurality of peers. 

3. The peer of claim 2, wherein the customized content comprises a current online 
auction posted by the user. 

4. The peer of claim 1 , wherein identity-based activity comprises instances of 
active content by a user logged-in to the instant messaging module. 

13 5 - The ^ of claim 4, wherein recently active content comprises multimedia files 

played back in the peer. 

6. The peer of claim 1, further comprises an application module to view identity- 
based content, and wherein the content daemon detects and stores identity-based activity in the 
application module. 

20 7 - The P^r of claim 1, wherein the content daemon detects and stores identity- 

based activity by communicating with an activity server that hosts the identity-based activity. 

8. The peer of claim 1 , wherein the content daemon detects and stores identity- 
based activity after logging-in the user to the instant messaging module, and wherein the 
instant messaging module sends an update to the recent identity-based activity. 

25 9 ■ The P eer of claim 1 , wherein the indication comprises a unique identifier 

related to the identity-based activity. 

10. The peer of claim 1 , further comprising a content transaction module to enable 
a transaction related to the identity-based activity. 
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11. A method of sharing identity-based activity with a plurality of peers, 



detecting identity-based activity; 
storing the identity-based activity, and 

sending an indication of recent identity-based activity to at least one of the plurality of 
peers, the recent identity-based activity related to a user logged-in to an instant 



12. The method of claim 1 1, wherein identity-based activity comprises content 
customized by the user that is accessible to the plurality of peers. 



70 13. The method of claim 12, wherein the customized content © 

online auction posted by the user. 

1 4. The method of claim 1 1 , wherein identity-based activity comprises instances of 
active content by a user logged-in to the instant messaging module. 

15. The method of claim 14, wherein recently active content comprises multimedia 
15 files played back in the peer. 

16. The method of claim 11, further comprising: 
viewing identity-based content; and 

detecting and storing identity-based activity. 

17. The method of claim 1 1, further comprises: 

20 detecting and storing identity-based activity independent of viewing identity-based 

activity. 

18. The method ofclaim 11, wherein the indication comprises a unique identifier 
related to the identity-based activity. 

19. The method of claim 1 1 , wherein the detecting comprises detecting identity- 
25 based activity of an application module in an operating system. 

20 . The method of claim 1 1, further comprising: 
enabling a transaction related to the identity-based activity. 
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21. A computer program product, comprising: 

a computer-readable medium having computer program instructions and data 

embodied thereon for sharing identity-based activity with a plurality of peers, 
comprising: 
5 detecting identity-based activity; 

storing the identity-based activity; and 

sending an indication of recent identity-based activity to at least one of the plurality of 
peers, the recent identity-based activity related to a user logged-in to an instant 



22. The computer program product of claim 2 1 , wherein identity-based activity 
comprises instances of active content by a user logged-in to the instant messaging module. 

23 . The computer program product of claim 2 1 , further comprising: 
detecting and storing identity-based activity independent of viewing identity-based 

activity. 

24. The computer program product of claim 21, wherein the indication comprises a 
unique identifier related to the identity-based activity. 

25 . The computer program product of claim 2 1 , further comprising: 
enabling a transaction related to the identity-based activity. 

26. A system for sharing information about an active content of a sender peer with 
a recipient peer, comprising: 

a sender peer comprising: 

a first application module, for activating and outputting active content from a 
data file; 

a first chat module, communicatively coupled to the first application module 
for sending information about the active content; and 



a second chat module, communicatively coupled to the first chat module, for 
receiving and outputting the information about the active content active 
on the sender peer. 
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27 . The system of claim 26, wherein the second chat module further comprises a 
client module for requesting a stream of the active content and the first chat module further 
comprises a server module for sending the stream of active content in response to the request. 

28 . The system of claim 27, the recipient peer further comprises a second 
5 application module for automatically activating the active content stream. 

29. The system of claim 28, wherein the stream is substantially synchronized with a 
portion of the active content currently active to the first application module. 

30. The system of claim 29, wherein the second application module allows active 
content playback control independent from the synchronized stream. 

10 31. The system of claim 26, wherein the active content information comprises a 

unique identifier. 

32. The system of claim 3 1 , wherein the recipient peer further comprises a content 
information database, and the second chat module is configured to use the unique identifier to 
retrieve local active content information from the content information database. 

15 33 . The system of claim 3 1 , wherein the recipient peer uses the unique identifier to 

retrieve active content information from an active content enhancement server. 

34. The system of claim 26, further comprising an active content enhancement 
server, communicatively coupled to the second chat module, for providing supplements related 
to the active content. 

20 35. The system of claim 34, wherein the content enhancement server further 

comprises a content transaction module for processing a purchase related to one or more 
sources containing the active content. 

36. The system of claim 34, wherein the active content enhancement server further 
comprises a content supplement database containing supplemental information related the 

25 active content. 

37. The system of claim 34, further comprising a content repository containing 
previews related to the one or more sources containing the active content, and the active 
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supplement database streams an active content preview to the recipient peer responsive to 
receiving a unique identifier. 

38. The system of claim 34, wherein the sender peer and the recipient peer are 
connnunicatively coupled through a first network, and the recipient peer and the content 

5 enhancement server are communicatively coupled through a second network. 

39. The system of claim 34, wherein the senderpeer further comprises a content 
repository for storing content activated by the first application module. 

40. The system of claim 34, wherein the first application module comprises a first 
media player, the second application module comprises a second media player, and a file 

JO format of the active content is compatible with the second application module. 

41. The system of claim 40, wherein the active content comprises an active media. 

42 . The system of claim 4 1 , wherein the active media comprises one from the 
group consisting of an audio file and a video file. 

43. The system of claim 26, wherein the information comprises a title and a type of 
15 the active content. 

44. The system of claim 26, wherein the first chat module is an instant messaging 
application. 

45 . The system of claim 26, wherein a display of the first chat module is integrated 
within a display of the first application module. 

20 46. The system of claim 26, wherein the first chat module sends updated active 

content information to reflect a change of active content. 

47. A method for sharing information about an active content of a first peer with a 



activating media content from a data file at a sender peer; 

sending real time information about the active media content from the sender peer to a 
recipient peer through a chat network connection responsive to detecting active 
media content on the senderpeer; and 

receiving and outputting information about the active media content at the recipient 
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48. The method of claim 47, further comprising: 

streaming the active media content from the sender peer to the recipient peer. 

49 . The method of claim 48, further comprising: 

activating the active media content stream substantially in real time with the activated 
media content at the recipient peer. 

50. The system of claim 47, further comprising: 

retrieving supplemental information about the active media content by querying a 
content enhancement server. 

5 1 . The method of claim 50, wherein the supplemental information includes 
graphic files related to the active media. 

52. The method of claim 47, further comprising: 

sending transaction information related to the active media content to the recipient peer 
responsive to the recipient peer receiving information about active media 
content; and 

processing a transaction related to the transaction information. 

53. The method of claim 52, wherein the transaction is a purchase of the active 
media content. 

54. The system of claim 47, wherein the activating comprises a first media player 
activating media content, and the receiving comprises a chat module receiving active media 



55 . The method of claim 47, wherein the active media content is an audio file. 

56. The method of claim 47, wherein the information comprises a title and a type of 
the active media content 

57. The method of claim 47, further comprising: 

updating active media content information at the recipient peer responsive to a change 
of active media content at the sender peer. 

58. A computer program product, comprising: 
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a computer-readable medium having computer program instructions and data 

embodied thereon for sharing information about an active content of a sender 
peer with a recipient peer, comprising: 

activating content from a data file at the sender peer; 
5 sending information about the active media content responsive to 

detecting active content from the sender peer, and 
receiving and outputting information about the active content at the 
recipient peer. 

59. The computer program product of claim 58, further comprising instructions and 
10 data for: 

streaming the active content through the peer-to-peer network to the recipient peer. 

60. The computer program product of claim 59, further comprising instructions and 
data for: 

activating the active content stream at the sender peer. 

15 6L Thec °raputer program product of claim 58, further comprising instaxctions and 

data for: 

retrieving supplemental information about the active content by querying a content 
enhancement server with a unique identifier. 

62. The computer program product of claim 58, further comprising instructions and 
20 data for: 

sending transaction information related to the active content to the recipient peer 

responsive to the recipient peer receiving information about active content; and 
processing a transaction related to the transaction information. 

63. The computer program product of claim 62, wherein the transaction is a 
25 purchase of the active content. 

64. The computer program product of claim 58, wherein activating comprises a 
first media player activating media content, and receiving comprises a chat module receiving 
active media content information. 

65. The computer program product of claim 58, wherein the active content 
30 comprises an active media content. 
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66. The computer program product of claim 58, further comprising instructions and 
data for: 

updating active content inforrnation at the recipient peer responsive to a change of 
active content at the sender peer. 

5 67. A recipient chat module in a system for sharing active content between a 

plurality of peers, comprising: 

a communications module for receiving a one or more unique identifiers based on 

shared active content on one or more sender peers; 
a graphical user interface module for outputting one or more shared active content 
1 0 information and receiving a selection of shared active content associated with 

one of the one or more sender peers; and 
a client module for sending a content stream request and receiving an active content 
stream. 

68. The recipient chat module of clam 67, wherein the content stream request 
IS comprises the unique identifier, and the recipient chat module sends the content stream request 
to a content enhancement server containing previews of the associated active content. 
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